$(function () {
  var layer = layui.layer
  var form = layui.form

  //调用函数
  initCate()
  // 初始化富文本编辑器
  initEditor()

  //定义加载文章分类方法
  function initCate() {
    $.ajax({
      method: 'GET',
      url: '/my/article/cates',
      success: function (res) {
        if (res.status !== 0) {
          return layer.msg('初始化文章分类失败！')
        }
        var htmlStr = template('tpl-cate', res)
        $('[name=cate_id]').html(htmlStr)
        // 一定要记得调用 form.render() 方法
        form.render()
      }
    })
  }
  // 1. 初始化图片裁剪器
  var $image = $('#image')

  // 2. 裁剪选项
  var options = {
    viewMode: 1,
    aspectRatio: 400 / 280,
    preview: '.img-preview'
  }

  // 3. 初始化裁剪区域
  $image.cropper(options)

  $('#btnChooseImage').on('click', function () {
    $('#coverFile').click()
  })

  // 监听 coverFile 的 change 事件，获取用户选择的文件列表
  $('#coverFile').on('change', function (e) {
    // 获取到文件的列表数组
    var files = e.target.files
    // 判断用户是否选择了文件
    if (files.length === 0) {
      return
    }
    // 根据文件，创建对应的 URL 地址
    var newImgURL = URL.createObjectURL(files[0])
    // 为裁剪区域重新设置图片
    $image
      .cropper('destroy') // 销毁旧的裁剪区域
      .attr('src', newImgURL) // 重新设置图片路径
      .cropper(options) // 重新初始化裁剪区域
    // 将value值清空
    e.target.value = ''
  })
  //定义文章发布状态
  var art_state = '已发布'
  $('btnSave2').on('click', function () {
    art_state = '草稿'
  })



  $("#form-pub").on('submit', function (e) {
    //阻止默认事件
    //preventDefault()[dom标准写法(ie678不兼容)]
    //ie678用returnValue
    //或者利用return false也能阻止默认行为,没有兼容问题(只限传统注册方式)
    e.preventDefault()
    //基于form表单，快速创建一个FormData
    var fd = new FormData($(this)[0])
    fd.append('state', art_state)

    $image.cropper('getCroppedCanvas', {
        // 创建一个 Canvas 画布
        width: 400,
        height: 280
      })
      .toBlob(function (blob) {
        // 将 Canvas 画布上的内容，转化为文件对象
        // 得到文件对象后，进行后续的操作
        // 5. 将文件对象，存储到 fd 中
        fd.append('cover_img', blob)
        // 6. 发起 ajax 数据请求
        $.ajax({
          method: 'POST',
          url: "/my/article/add",
          data: fd,
          processData: false,
          contentType: false,
          success: function (res) {
            // console.log(222);
            if (res.status !== 0) {
              return layer.msg('发布失败')
            }
            layer.msg('发布成功')
            // alert('hah')
            //console.log(1);
            // 发布成功跳转
            window.parent.document.querySelector('#art_list_dd').click()

          } 
        })
      })
  })

})